//引入用户集合的构造函数
const { User } = require('../../model/user');
//引入加密模块
const bcrypt = require('bcryptjs');

module.exports = async(req, res, next) => {

    try {
        await validateUser(req.body)
    } catch (e) {
        //验证没有通过
        //  e.message
        //重定向回用户添加页面
        //    return res.redirect(`/admin/user-edit?message=${e.message}`)
        //JSON.stringify() 将对象数据类型转换为字符串数据类型

        return next(JSON.stringify({ path: '/admin/user-edit', message: e.message }));
    }


    //根据邮箱地址查询用户是否存在
    let user = User.findOne({ email: req.body.email })
        //如果用户已经存在 邮箱地址已经被别人占用
    if (user) {
        //重定向回用户添加页面
        // return res.redirect(`/admin/user-edit?message=邮箱地址已经被占用}`)
        return next(JSON.stringify({ path: '/admin/user-edit', message: '邮箱地址已经被占用' }))

    }
    //对密码进行加密处理
    //生成随机字符串
    const salt = await bcrypt.genSalt(10);
    //加密
    const password = await bcrypt.hash(req.body.password, salt);
    // 替换密码
    req.body.password = password;
    // res.send(req.body);
    //将用户信息添加到数据库中
    await User.create(req.body);
    //将页面重定向到用户列表页面
    res.redirect('/admin/user');
}